



⑯ Europäisches Patentamt  
European Patent Office  
Office européen des brevets

⑮ Publication number:

0 394 162  
A2

⑯

## EUROPEAN PATENT APPLICATION

⑯ Application number: 90480033.1

⑮ Int. Cl. 5: G06F 7/52

⑯ Date of filing: 07.03.90

⑯ Priority: 17.04.89 US 339261

⑯ Date of publication of application:  
24.10.90 Bulletin 90/43

⑯ Designated Contracting States:  
DE FR GB

⑯ Applicant: International Business Machines  
Corporation  
Old Orchard Road  
Armonk, N.Y. 10504(US)

⑯ Inventor: Allen, Richard George  
2315 Telemark Lane N.W.  
Rochester, Minnesota 55901(US)  
Inventor: Freerksen, Donald Lee  
1220 41/2 Street N.W.  
Rochester, Minnesota 55901(US)

⑯ Representative: Vekemans, André  
Compagnie IBM France Département de  
Propriété Intellectuelle  
F-06610 La Gaude(FR)

⑯ Two-bit floating point divide circuit with single carry-save adder.

⑯ Apparatus and method for performing floating point divide operations in 2-bit, non-restoring iterations, wherein multiples of the divisor are formed by selective gating of one or more representations of the divisor into a single 3-input adder circuit, to calculate the partial quotients and subsequent partial dividends. The apparatus produces, without the need of separate holding registers, the zero, 1/2, 3/4, 1 and 3/2 multiples of the divisor.



Fig. 2

## TWO-BIT FLOATING POINT DIVIDE CIRCUIT WITH SINGLE CARRY-SAVE ADDER

The present invention relates to a method and apparatus for performing certain floating point arithmetic operations in a data processing system. More particularly, the invention relates to an apparatus and method for implementing the apparatus, wherein five multiples of the divisor are produced without additional registers, for use in the divide iterations to produce a quotient, and wherein the floating point division circuit

5 has a single carry-save adder circuit.

The use of floating point arithmetic operations in a data processing system has been a common practice practically since the inception of computer technology. The development of floating point arithmetic hardware has taken many forms, usually with the objectives of simplifying the hardware construction, or enhancing the speed of the arithmetic processing operation. The four arithmetic operations of add, subtract,

10 multiply and divide have usually been accomplished by using specialized subsets of processes involving addition and subtraction. For example, multiplication operations have in many cases been performed by repeated addition processes, and division has been accomplished by a process of repeated subtraction. The efforts made to speed up these processing operations have focused on enhancements and simplifications of hardware circuit design, particularly the adder circuit, which ultimately limits the maximum

15 processing speed of all arithmetic operations. In the case of division, efforts have been made to increase the speed of operation by calculating partial quotients, or by simultaneously predicting multiple quotient bits, to reduce the number of addition or subtraction iterations required for the divide calculation.

An American national standard has been developed in order to provide a uniform system of rules for governing the implementation of floating point arithmetic systems. This standard is identified as ANSI/IEEE Standard No. 754-1985, and is incorporated by reference herein. In the design of floating point arithmetic systems and algorithms, it is a principal objective to achieve results which are consistent with this standard, to enable users of such systems and algorithms to achieve conformity in the calculations and solutions to problems even though the problems are solved using different computer systems. The standard specifies basic and extended floating point number formats, arithmetic operations, conversions between integer and

20 floating point formats, conversions between different floating point formats, conversions between basic format floating point numbers and decimal strings, and the handling of certain floating point exceptions.

The typical floating point arithmetic operation may be accomplished in either single precision or double precision format. Each of these formats utilizes a sign, exponent and fraction field, where the respective fields occupy predefined portions of the floating point number. In the case of a 32-bit single precision number the sign field is a single bit occupying the most significant bit position; the exponent field is an 8-bit quantity occupying the next-most significant bit positions; the fraction field occupies the least significant 23-bit positions. In the case of a double precision floating point number the sign field is a single bit occupying the most significant bit position; the exponent field is an 11-bit field occupying the next-most significant bit positions; the fraction field is a 52-bit field occupying the least significant bit positions.

35 After each floating point answer is developed, it must be normalized and then rounded. When the answer is normalized, the number of leading zeros in the fraction field is counted. This number is then subtracted from the exponent and the fraction is shifted left until a "1" resides in the most significant bit position of the fraction field. Certain floating point answers cannot be normalized because the exponent is already at its lowest possible value and the most significant bit of the fraction field is not a "1."

40 In designing the hardware and logic for performing floating point arithmetic operations in conformance with ANSI/IEEE Standard 754-1985, it is necessary and desirable to incorporate certain additional indicator bits into the floating point hardware operations. These indicator bits are injected into the fraction field of the floating point number, and are used by the arithmetic control logic to indicate when certain conditions exist in the floating point operation. For example, an "implicit" bit I is created by the arithmetic control logic when

45 the exponent of the floating point number has a nonzero value. The implicit bit I is created at the time a floating point number is loaded into the arithmetic registers, and the implicit bit I occupies the first bit position in the fraction field of the number. In addition, a "guard" bit G is set by the floating point control logic during certain arithmetic operations, as an indicator of the loss of precision of the floating point number being processed. The G bit

50 is set when a right shift, required for normalization, shifts a significant bit off the right side of the register capacity. For single precision numbers the G bit occupies bit position 25 in the fraction field; for double precision numbers the G bit occupies position 54 in the fraction field. A "round" bit R is similarly used for certain floating point arithmetic operations, and is set by the arithmetic control logic, and the R bit occupies bit position 26 in the fraction field of a single precision number, and bit position 55 in the fraction field of a double precision number. Finally, a "sticky" bit S is an indicator bit which is set in certain floating point

arithmetic operations when any lower precision bit is a "1," as an indicator that the floating point number has lost some precision. The S bit occupies position 27 of the fraction field in a single precision floating point number, and position 56 in the fraction field of a double precision floating point number.

The three extra bits in the fraction field are used exclusively for rounding operations, after the result has

5 been normalized. The guard (G) and round (R) bits are treated as if they are a part of the fraction; they are shifted with the rest of the fraction, and included in all arithmetic. The sticky (S) bit is not shifted with the fraction, but is included in the arithmetic. It acts as a "catcher" for 1's shifted off the right of the fraction; when a 1 is shifted off the right side of the fraction, the S bit will remain a 1 until normalization and rounding are finished.

10 In a rounding operation there are typically four modes of rounding which are used, as follows:

- 1) round to nearest;
- 2) round to positive infinity;
- 3) round to negative infinity;
- 4) round to zero.

15 The "round to nearest" mode means that the value nearest to the infinitely precise result should be delivered. If the two nearest representable values are equally near, the one with its least significant bit zero shall be delivered. The "round to positive infinity" mode means that the value closest to and not less than the infinitely precise result should be delivered. The "round to negative infinity" mode means that the value closest to and not greater than the infinitely precise result should be delivered. The "round to zero" mode means that the result delivered should be the closest to but not greater in magnitude than the infinitely precise result. If none of the G, R, and S bits are a "1," no rounding will be accomplished regardless of the mode of rounding selected.

20 Unfortunately, any arithmetic circuit utilizing an adder for carrying out an addition or subtraction inevitably involves the generation of carry bits which are propagated from least significant bit positions to more significant bit positions, and can in fact be propagated throughout all bit positions during an arithmetic 25 operation. This has the effect of extending the processing time required for completing a calculation, and various design efforts have been made to deal with this problem. For example, U.S. Patent No. 4,754,422, discloses a dividing apparatus utilizing three carry-save adders in an effort to produce a plurality of quotient bits during each iteration or cycle of arithmetic operation. U.S. Patent No. 3,621,218, discloses a high-speed 30 divider utilizing a single carry-save adder for producing a plurality of quotient bits during each iteration of the arithmetic operation, and a plurality of registers for holding a sequence of partial quotients used in the operation.

35 IBM Technical Disclosure Bulletin, Volume 14, No. 11, April 1972 (pages 3279-3281) discloses a divider for producing two quotient bits per iteration, utilizing two carry-save adders and certain multiples of the divisor to speed up the operation.

40 The present invention is an improvement over the foregoing disclosures, for generating two quotient bits per iteration by producing five multiples of the divisor, with the improved feature of using only a single carry-save adder, and no additional registers for holding the divisor multiples. It is therefore a principal object of this invention to provide a floating point divide circuit, and method for operating the circuit, which generates two quotient bits per iteration by producing five multiples of the divisor without requiring additional registers, and utilizes only a single carry-save adder.

45 It is a further object of the present invention to provide a floating point division circuit capable of generating two quotient bits per iteration, by utilizing a circuit common to other floating point arithmetic operations such as add, subtract and multiply.

It is a further object of the present invention to provide an apparatus and method for floating point 50 arithmetic operations, wholly in conformance with ANSI/IEEE Standard No. 754-1985.

It is a further object of the present invention to provide an apparatus and method for achieving certain floating point arithmetic operations in a shorter time period than previously obtained, through the selective reduction in the number of machine cycles required to provide these operations.

55 The invention includes registers for holding a divisor, dividend, and partial dividends, coupled to a single carry-save adder and carry-propagate adder, with a particular method for sequencing the divisor in order to produce two quotient bits for each iteration. To produce two quotient bits for each iteration, the multiples of the divisor that are required are the zero, 1/2, 3/4, 1, and 3/2 multiples; all of the multiples are produced by selective gating into the carry-save adder from the divisor register, using preselected latches in a multiple selector logic circuit. The zero multiple is created by inhibiting the gating from the divisor register; the one multiple is created by directly gating the divisor register; the 1/2 multiple is created by gating the divisor register displaced one bit position to the right; the 3/4 multiple is created by simultaneously gating the divisor shifted one position to the right (1/2) and also gating the divisor shifted two positions to the right (1/4); the 3/2 multiple is created by gating the 1 multiple and the 1/2 multiple; all

gating being done into one or two inputs to the carry-save adder. Since the carry-save adder can accommodate three input operands, this permits a divide iteration requiring only the divisor, and dividend or partial dividend to be stored in a register. The sequencing method includes the addition or subtraction of the multiples of the divisor to the dividend or partial dividend to produce a new partial dividend, which is shifted leftward by two positions for each iteration. The higher order bits of the divisor and dividend or partial dividend are decoded during each iteration to select the next divisor multiple; the quotient bits are decoded by examination of the partial dividend at the start of an iteration and at the end of an iteration, and examining the selected divisor multiple, to select the proper quotient bits for the iteration.

5 FIG. 1 shows a block diagram of a floating point arithmetic circuit used with the present invention;

10 FIG. 2 shows a block diagram of the divisor multiple selection circuits; and

FIG. 3 shows a flow chart of the method for sequencing the apparatus of FIG. 1 and FIG. 2.

Referring first to FIG. 1, there is shown a block diagram of the floating point arithmetic circuit which is used in conjunction with the present invention. The execution of floating point arithmetic utilizes this circuit because of the specific algorithms which must be performed to determine the proper results. This circuit presumes that the floating point numbers have been prearranged according to a particular format, where the 15 most significant bit represents the sign of the floating point number, and wherein a group of the next-most significant bits represent the exponent of the floating point number, and wherein the remaining bits represent the fraction value of the number; i.e., the fraction value presuming that decimal point is placed at the left-most end of the fraction value. In the case of floating point arithmetic utilizing single precision 20 calculations wherein the size of the number is 32 bits, the sign bit is presumed to be bit 0, the exponent bits are 1-8, and the fraction value bits are 9-31. In the case where the floating point arithmetic is accomplished utilizing double precision numbers, the sign bit is bit 0, the exponent bits are 1-11, and the fractional value bits are 12-63. In addition to the foregoing identified bits, the hardware registers and logic associated with FIG. 1 include four additional bits: the I bit occupies the most significant position in the 25 fraction field, and the G, R and S bits respectively occupy the least significant bit positions in the fraction field.

Floating point operands cannot be added to or subtracted from each other unless their exponents are equal. This requires that their exponents be compared, and the operand fraction with the smaller exponent be shifted the amount of the exponent difference. The fractions can then be added or subtracted with the 30 larger exponent as the result exponent. Multiplication of floating point operands requires that the exponents be added and the fractions multiplied. Division of floating point operands requires that the divisor exponent be subtracted from the dividend exponent and the dividend fraction be divided by the divisor fraction.

The floating point arithmetic circuit of FIG. 1 can support both single and double precision arithmetic operations. It is designed to support a floating point add or subtract operation, a multiply operation that 35 retires 4 bits of multiplier per iteration, and a divide operation that generates two quotient bits per iteration.

The floating point arithmetic circuit 10 of FIG. 1 utilizes a storage data buss 12 for receiving and transmitting data from other sources, such as a data processing system or the like. Information received over data storage buss 12 may be transmitted into a plurality of floating point registers 14. In the preferred embodiment there are eight floating point registers 14, each adapted to hold the floating point operands and 40 the results of floating point operations. Floating point registers 14 may transmit information to an FA register 16, an FB register 18, or an FC register 22. FA register 16 may also transmit information back to floating point registers 14.

The FA register 16 is a destination register for data from the floating point registers 14, and is the 45 source register for data being transmitted to the floating point registers 14. The FA register 16 is also the source register for data which may be transferred to a memory via storage data buss 12, and it is a destination register for data transmitted from the carry-propagate adder 30, the exponent adder 20, and from the normalize-round circuit 34. The FA register 16 has outputs to the multiple selector 24, the prealigner circuit 26; the normalize-round circuit 34, and the exponent adder 20. The FA register 16 contains the second operand for add, subtract, compare, multiply and divide operations. FA register 16 has 50 a section 16a for holding the exponent of the floating point number, and a section 16b for holding the fraction portion of the floating point number.

In order to selectively control which of the plurality of inputs to the FA register 16 are to be gated into the register, the FA register 16 has an input multiplexer circuit 15 associated therewith. Multiplexer circuit 55 15 provides for the selective gating of the various inputs into register 16, under control of an activation signal A. Other registers in the floating point arithmetic circuit 10 have similar multiplexer input controls.

A control logic circuit 11 generates all of the activation signals required for data interchange and processing operations within floating point arithmetic circuit 10. Control logic circuit 11 has a plurality of control signal outputs, designated A, each of which serve as control inputs to various circuits and registers.

It is well within the skill of the art to understand the need and design for a control logic circuit 11, as well as the activation signals A which are required for the operation of floating point arithmetic circuit 10; accordingly, a detailed presentation of these circuits and signals is not required herein. Control logic circuit 11 also receives the most significant three bits from the FA register section 16b, and from the FB register 18b; it also receives the most significant three bits from the carry-propagate adder 30 via 3-bit decode circuit 36. Control logic 11 has decoding circuitry therein for decoding the respective 3-bit values, and for activating a particular activation signal A which is transmitted to the multiple selector logic 24 for the purpose of selecting appropriate latches. Control logic 11 also has decoding logic for detecting whether the FB register section 18b value is true or complement, for detecting whether the carry-propagate adder 30 output is true or complement, and for detecting the particular latch signal A which has been activated during any divide iteration. Control logic 11 utilizes these signals to generate a 2 or 3-bit quotient value Q, which it transfers to the lower two positions of the input multiplexer section 21, associated with FC register 22.

The FB register 18 is a destination register for data received from the storage data buss 12, the floating point registers 14, and is also a destination register for data from the carry-propagate adder 30, and from the normalize-round circuit 34. It has outputs to the multiple selector 24, the prealigner circuit 26, and the exponent adder 20. The FB register is used to contain the first operand for the add, subtract, compare and divide operations; it also contains the intermediate result of the add, subtract, multiply, and divide operations. The FB register 18 has a section 18a for containing the exponent value of the floating point number, and a section 18b for containing the fraction portion of the floating point number, and has an input multiplexer circuit 17 for gating data into the register under control of activation signals from control logic circuit 11. For divide it contains the dividend and subsequent partial dividends.

The FC register 22 is a destination register for data from memory via storage data buss 12, and a destination register for data from the carry-propagate adder 30 and from the normalize-round circuit 34. It is also the destination register from the floating point registers 14. The FC register 22 has outputs to the multiple selector 24, the prealigner circuit 26, and the normalize-round circuit 34. The FC register 22 is used to contain the first operand of the multiply operation, and it is the destination register for the quotient of a divide operation. An input multiplexer circuit 21 controls the gating of data into FC register 22, under control of activation signals from control logic circuit 11.

The exponent adder 20 is a 13-bit adder circuit that is used for exponent arithmetic. It handles the exponent calculations for either single or double precision exponents. The exponent adder is a source for data transmitted to FA register section 16a, and FB register section 18a. The exponent adder 20 has an input multiplexer circuit 19.

The prealigner circuit 26 is used to pre-shift the fraction with the smaller exponent for the add and subtract operation, which is necessary to make the floating point operand exponents equal prior to an add or subtract operation. The prealigner circuit 26 has the capability to shift a floating point fraction right from 0 to 55 bit positions, depending upon whether single or double precision arithmetic is being performed. The prealigner circuit 26 has an output to the carry-propagate adder 30, and to the FC register 22.

The multiple selector 24 is a logic circuit which gates multiples of the multiplicand for the multiply operation, and multiples of the divisor for the divide operation. For the divide operation, the multiples are by the control logic 11 from a decoding of the high-order bits of the dividend, or partial dividend, and of the divisor. The complement of the operand may be generated by the multiple selector when necessary. The multiple selector 24 receives data from the FA register 16, the FB register 18, and the FC register 22. The multiple selector 24 has outputs to the carry-save adder 28.

The carry-save adder 28 will permit three operands to be added together at the same time. This permits the use of a divide algorithm which generates two quotient bits per iteration. The carry-save adder 28 receives data from the multiple selector 24, and transmits data to the carry-propagate adder 30. The carry-save adder 28 may operate according to the principal of 2's complement subtraction, but in any event the results it produces for division are effectively to subtract the divisor (or a multiple of the divisor) from the dividend (or partial dividend) to form a quotient (or partial quotient) over a series of iterations, in conjunction with the carry-propagate adder 30.

The carry-propagate adder 30 is a 57-bit adder, and has an input from the carry-save adder 28 for generating the partial product of a multiply operation or the partial dividend of a divide operation. The carry-propagate adder circuit 30 may also receive inputs from the prealigner circuit 26, the FA register 16, and the FB register 18. The carry-propagate adder has an output connection to the FA register 16 and the FB register 18. An input multiplexer circuit 29 controls the gating of data into carry-propagate adder 30, under control of activation signals A from control logic circuit 11. The most significant bits output from the carry-propagate adder 30 are monitored by a 3-bit decode circuit 36, for use in connection with the divide

operation to be hereinafter described.

The normalize-round circuit 34 includes a normalize circuit 34a which is used to normalize the results of a floating point operation. For example, the result of a multiply operation may require a right-shift of one bit in order to normalize the fraction, and the result of an add or subtract operation may require a left-shift of 5 up to 54 bit positions. The normalize-round circuit 34 also includes a round circuit 34b, which contains an incrementor circuit, for use in certain rounding operations, where the result may have to be incremented by a value of 1 in the low-order bit position.

Before a divide operation can take place, both the divisor and the dividend must be normalized. The divisor is initially placed into the FA register 16, and the dividend is initially placed in the FB register 18. 10 The divisor is normalized by gating the fractional quantity found in FA register 16b into the prealigner circuit 26, shifting the fractional quantity left by the number of leading zeros in the fraction field, and restoring the shifted value back into the FA register 16b. The number of shifts recorded is subtracted from the exponent value initially contained in FA register 16a, by a subtraction operation performed in the exponent adder circuit 20. After this subtraction is performed the subtracted value is gated back into the FA register 15 exponent portion 16a.

The dividend is normalized by gating the fractional quantity found in FB register 18b to the prealigner 26, shifting it left by the number of leading zeros found in the fraction, and restoring the shifted value back to the FB register 18b. The exponent value in FB register 18a is subtracted by the number of shifts recorded from the fraction shift operation, through the exponent adder circuit 20, and the subtracted value 20 of the exponent is restored into FB register 18a.

An initialization cycle is required for the divide iterations. This is accomplished by initializing a counter to count the iterations; 13 for single precision, and 28 for double precision. The three most significant bits of the fractions in the FA register 16b and the FB registers 18b are monitored by control logic 11 to determine the divisor multiple which is to be used for the first iteration. The determination of this multiple will be 25 described hereinafter, with reference to FIGS. 2 and 3. The exponents in the FA register 16a and the FB register 18a are gated to the exponent adder, and the FA exponent is subtracted from the FB exponent, with the result being placed into the FA register 16a. After this initialization cycle is completed the circuit of FIG. 1 may then be utilized to perform a sequence of 13 divide iterations for single precision numbers, or 28 divide iterations for double precision numbers. The fractional dividend, or partial dividend, found in 30 register section 18b, is divided by the fractional divisor, found in register section 16b, through a series of subtractive iterations. The divide sequence requires a non-restoring uniform shift of two bits during each iteration. It requires the 0, 1/2, 3/4, 1, and 3/2 multiples of the divisor to be selectable by the multiple selector 24, to produce a partial dividend that can be shifted left by two bits for each iteration, and which 35 will produce two quotient bits for each iteration. The quotient ultimately will appear in the FC register 22, and the partial dividends will be developed in register section 18b during the operation.

FIG. 2 shows a portion of the floating point arithmetic circuit 10 of FIG. 1, which is associated with the selection of the divisor multiple to be used during each iteration of the divide operation. In the first cycle of the divide operation, control logic 11 monitors the most significant three bits of register 16b, designated 16b' in FIG. 2, and also monitors the most significant three bits of register 18b, designated 18b' in FIG. 2. 40 Control logic 11 utilizes these quantities in its internal decision logic to determine the initial divisor multiple to be used in the divide operation. This determination results in the generation of a particular activation signal A', which is coupled to one or more latches in multiple selector 24. The respective latches permit selective gating of the fractional divisor held in register 16b into carry-save adder 28. For example, one A' signal will activate the latch designated 1:1, which permits the fractional contents of register 16b to be directly transferred to an input of carry-save adder 28; another activation signal A' activates the latch 45 designated 1:1/2, which permits the fractional contents of register 16b to be gated to an input of carry-save adder 28, which with each bit shifted one position rightward from its respective position in register 16b; a third activation signal A' activates a latch 1:1/4, which permits the gating of the fractional contents of register 16b into an input of carry-save adder 28, shifted two bit positions to the right from the respective 50 position of the fraction in register 16b. In this manner, control logic 11 can generate an activation signal A' which gates either the divisor, or 1/2 divisor, or 1/4 divisor into carry-save adder 28 inputs. Since carry-save adder 28 has three inputs, and is capable of adding the values represented at these three inputs, it is possible to combine activation of two latches to provide a combinatorial multiple, for example, if the latch designated 1:1/2 and the latch designated 1:1/4 are both activated, 1/2 divisor will appear at one carry-save adder 28 input and 1/4 divisor will appear at a second carry-save adder input, the sum of which will equal 55 3/4 divisor. Likewise, if the latch designated 1:1 is simultaneously activated with the latch designated 1:1/2, the divisor and 1/2 divisor are simultaneously gated to inputs of the carry-save adder 28, the sum of which will produce 3/2's divisor. The zero divisor can be produced by merely inhibiting all gating from register 16b

into carry-save adder 28, thereby producing a zero input to carry-save adder 28. Therefore, it is readily possible for control logic 11 to produce the zero, 1/2, 3/4, 1, and 3/2 multiples of the divisor during any iteration of the divide cycle.

After the initial activation of the divide cycle, control logic 11 selects the divisor multiple for subsequent iterations through examination of the most significant three bits output from the carry-propagate adder 30, via a 3-bit decode circuit 36.

Control logic 11 is also coupled to register 18b and carry-propagate adder 30 to sense the most significant fractional carry bit to determine whether the current value is a true or complement number, particularly comparing the value of the partial dividend both before and after each iteration. This comparison, together with an examination of the divisor multiple used during the iteration, enables the circuit to predict whether the subtraction operation which occurs during the iteration has changed the sign of the partial dividend. If the sign has changed, the divisor multiple selected is too large, and the resulting quotient bits should be reduced or increased by a predetermined value, dependent upon the multiple used for the iteration. Control logic 11 contains an internal decision circuit which enables this comparison to be made, and which results in the selection of the appropriate quotient, dependent upon these variables. The quotient may be a 2-bit quotient Q, or in certain instances a 3-bit quotient Q. In the one case where a divisor multiple of 3/4 is used during the iteration, a 3-bit quotient is produced; in all other instances a 2-bit quotient value is produced. In the case of a 3-bit quotient value, and in the case of a 2-bit quotient value, the value itself is transferred to input multiplexer section 21 at the lowest two (or three) bit positions. If a 3-bit quotient value is selected, the most significant quotient bit produced as a result of the next iteration is ignored, and the next iteration results in the transfer of a 1-bit quotient value to the input multiplexer 21.

TABLE 1 shows a table for selecting the divisor multiple as a function of the dividend, or partial dividend. The high-order three bits of the divisor and the high-order three bits of the dividend (partial dividend after the first iteration) are decoded according to the tabulation of TABLE 1 to select the multiple of the divisor for the next iteration. For example, if the high-order three bits of the true dividend are 011, and the high-order two bits of the divisor are 110, the multiple of the divisor for the next iteration which is selected will be the 1/2 times multiple of the divisor. The decoding conventions shown in TABLE 1 insures that the partial dividend can be shifted two bit positions and therefore, at least two quotient bit positions bits can be generated.

30

TABLE 1

| TRUE<br>DIVIDEND | DIVISOR |     |     |     | COMPLEMENT<br>DIVIDEND | DIVISOR |     |     |     |
|------------------|---------|-----|-----|-----|------------------------|---------|-----|-----|-----|
|                  | 100     | 101 | 110 | 111 |                        | 100     | 101 | 110 | 111 |
| 000              | 0       | 0   | 0   | 0   | 000                    | 3/2     | 3/2 | 1   | 1   |
| 001              | 0       | 0   | 0   | 0   | 001                    | 3/2     | 1   | 1   | 1   |
| 010              | 1/2     | 1/2 | 1/2 | 1/2 | 010                    | 1       | 1   | 1   | 3/4 |
| 011              | 1/2     | 1/2 | 1/2 | 1/2 | 011                    | 1       | 1   | 3/4 | 3/4 |
| 100              | 1       | 1   | 3/4 | 3/4 | 100                    | 1/2     | 1/2 | 1/2 | 1/2 |
| 101              | 1       | 1   | 3/4 | 3/4 | 101                    | 1/2     | 1/2 | 1/2 | 1/2 |
| 110              | 3/2     | 1   | 1   | 1   | 110                    | 0       | 0   | 0   | 0   |
| 111              | 3/2     | 3/2 | 1   | 1   | 111                    | 0       | 0   | 0   | 0   |

TABLE 2 shows a table for selecting at least a pair of quotient bits as a function of the partial dividend value and the divisor multiplier selected, according to non-restoring division techniques. The quotient bits which are selected depend upon three conditions

(1) whether the partial dividend at the start of the iteration is true or complement;  
 (2) whether the partial dividend at the end of the iteration is true or complement;  
 (3) which multiple was used during the iteration. For example, if the partial dividend at the start of the iteration was true, and the partial dividend at the end of the iteration was true, and the 1/2 times multiple was used during the iteration, the quotient bits selected will be 01. In the case when the 3/4 times multiple is used during the iteration, three quotient bits are generated. These three quotient bits are all valid, and the third bit must be used in place of the high-order bit that is generated on the next iteration.

TABLE 2

| 5  | STARTING<br>PARTIAL<br>DIVIDEND | ENDING<br>PARTIAL<br>DIVIDEND | DIVISOR MULTIPLIER USED |    |     |     |    |
|----|---------------------------------|-------------------------------|-------------------------|----|-----|-----|----|
|    |                                 |                               | 3/2                     | 1  | 3/4 | 1/2 | 0  |
| 10 | T                               | T                             | 11                      | 10 | 011 | 01  | 00 |
|    |                                 | C                             | 10                      | 01 | 010 | 00  | -  |
| 15 | C                               | T                             | 01                      | 10 | 101 | 11  | -- |
|    |                                 | C                             | 00                      | 01 | 100 | 10  | 11 |

15 FIG. 3 shows a flow chart of the divide iterations according to the teachings of the present invention. The left side of FIG. 3 illustrates the machine cycles which are required for divide iterations, wherein cycle 1 is defined as an initial cycle for setting up the first iteration, and cycles 2-14 are the iteration cycles for single precision numbers (cycles 2-29 for double precision numbers), and the final cycle is devoted to postnormalized and round operations. The postnormalize and round operations may be accomplished according to usual techniques which are well known in the art.

20 In cycle 1 of the divide operation, the three most significant bits of the fractional quantity contained in register 16b and register 18b are examined and decoded by control logic 11. Control logic 11 then generates an activation signal A' for selecting a particular multiple latch as has been hereinbefore described, and which results in the selection of the multiple illustrated in Table 1.

25 After the foregoing selection has been accomplished the binary value contained in register 16b is gated into carry-save adder 28 via the latching network hereinbefore described, and is subtracted from the binary value contained in register 18b. As has been hereinbefore indicated, the subtracted value may be any of the five multiples of the divisor which have been described.

30 The results of this subtraction are transferred from the carry-propagate adder 30 to input multiplexer section 17; the most significant three bits of the result from carry-propagate adder 30 is received by the 3-bit decode circuit 36.

35 Control logic 11 then senses the three most significant bits in register 16b, and the 3-bit value found in decode circuit 36, and determines whether the respective values are true or complement values; control logic 11 also checks the multiple latch which was selected for the last subtraction. Control logic 11 then generates a 2-bit quotient Q (3-bits if multiplier was 3/4), wherein Q is generated from an internal decision circuit which is illustrated in Table 2.

40 Control logic 11 then transfers the Q value to input multiplexer section 21, at the least significant bit positions, and then transfers the input multiplexer section 17 contents into register 22, two bit positions to the left of the least significant bit. Control logic 11 also transfers the input multiplexer 17 into register 18b to form the new partial dividend.

45 Control logic 11 then examines the three most significant bits in register 16b, and also examines the contents of 3-bit decode circuit 36, to make a determination through internal decision logic as to the selection of the next multiple. This multiple is selected according to the internal decision logic which is illustrated in Table 1. A new subtraction is made, and this process continues until all of the iterations for the particular divide operation have been completed.

50 At the completion of the divide iterations control logic circuit 11 then transfers the contents of register 18 into the normalize and round circuits 34a and 34b for postnormalize and round operations, according to the teachings of the art. Postnormalize and round occurs during a final cycle of the divide operation, and at the completion of the divide operation the quotient is found in register 22, the remainder is found in register 18, and the original divisor is still found in register 16.

### Claims

55 1. An apparatus for performing a 2-bit, non-restoring floating point divide operation in a series of iterations, comprising  
a) a divisor register for holding the divisor of said divide operation;  
b) a dividend register for holding the dividend of said divide operation and subsequent partial

dividends during respective iterations;

- c) a quotient register for holding partial quotients during respective iterations and the quotient result;
- d) an adder circuit having three inputs for receiving operands, one of said inputs being coupled to said dividend register;
- 5 e) a multiple selector circuit having respective outputs connected to the remaining two inputs of said adder circuit, and having inputs connected to said divisor register, and having means for selectively gating multiples of said divisor into said adder circuit, controllable by activation signals; and
- f) a control logic circuit having means for sensing the three most significant divisor register bits and the three most significant dividend register bits, and having means for generating said activation signals in response thereto, to selectively gate certain multiples of said divisor into said adder circuit; said control logic circuit also having means for formulating partial quotients as a function of the dividend register contents before and after each of said iterations and the divisor multiples selected for said iteration.

10 2. The apparatus of claim 1, wherein said multiple selector circuit further comprises a plurality of latches connected to said adder circuit two inputs and to outputs of said divisor register, said latches being controllable by said activation signals to gate said divisor register outputs to said adder circuit inputs in predetermined bit position transfers.

15 3. The apparatus of claim 2, wherein said latches further comprise means for making said predetermined bit position transfers to formulate the zero, 1/2, 3/4, 1 and 3/2 multiples of said divisor.

20 4. The apparatus of claim 3, wherein said means for making said predetermined bit position transfers for formulating the 3/2 multiple of said divisor further comprises means for simultaneously gating said divisor to one input of said adder circuit, and gating said divisor shifted by one bit position rightward to a second input of said adder circuit.

25 5. The apparatus of claim 4, wherein said means for making said predetermined bit position transfers for formulating the 3/4 multiple of said divisor further comprises means for simultaneously gating said divisor shifted by one bit position rightward to one input of said adder circuit, and gating said divisor shifted by two bit positions rightward to a second input of said adder circuit.

6. The apparatus of claim 5, wherein said means for making said predetermined bit position transfers for formulating the one multiple of said divisor further comprises means for gating said divisor directly into one input of said adder circuit, and inhibiting the gating into a second input of said adder circuit.

30 7. The apparatus of claim 6, wherein said means for making said predetermined bit position transfers for formulating the 1/2 multiple of said divisor further comprises means for gating said divisor shifted one bit position rightward to one input of said adder circuit, and inhibiting the gating into a second input of said adder circuit.

35 8. The apparatus of claim 7, wherein said means for making said predetermined bit position transfers for formulating the zero multiple of said divisor further comprises means for inhibiting the gating into two inputs of said adder circuit.

9. The apparatus of claim 4, further comprising a 3-bit decoder circuit connected to the output of said adder circuit, said 3-bit decoder having means for sensing the three most significant bits output from said adder circuit.

40 10. The apparatus of claim 9, wherein each of said dividend register, said divisor register and said 3-bit decoder circuit has means for storing the sign value of the number contained therein or at the output of said adder circuit respectively, and said control logic circuit further comprises means for sensing said sign values and determining thereby whether the respective numbers are true or complement values.

45 11. The apparatus of claim 10, wherein said control logic circuit further comprises means for selecting predetermined divisor multiples for each iteration of said divide operation as a function of the true/complement value and the most significant three bits of the respective divisor and partial dividends according to the following tabulation:

| 5  | TRUE DIVIDEND | DIVISOR |     |     |     | COMPLEMENT DIVIDEND | DIVISOR |     |     |     |
|----|---------------|---------|-----|-----|-----|---------------------|---------|-----|-----|-----|
|    |               | 100     | 101 | 110 | 111 |                     | 100     | 101 | 110 | 111 |
| 10 | 000           | 0       | 0   | 0   | 0   | 000                 | 3/2     | 3/2 | 1   | 1   |
|    | 001           | 0       | 0   | 0   | 0   | 001                 | 3/2     | 1   | 1   | 1   |
|    | 010           | 1/2     | 1/2 | 1/2 | 1/2 | 010                 | 1       | 1   | 1   | 3/4 |
|    | 011           | 1/2     | 1/2 | 1/2 | 1/2 | 011                 | 1       | 1   | 3/4 | 3/4 |
|    | 100           | 1       | 1   | 3/4 | 3/4 | 100                 | 1/2     | 1/2 | 1/2 | 1/2 |
|    | 101           | 1       | 1   | 3/4 | 3/4 | 101                 | 1/2     | 1/2 | 1/2 | 1/2 |
|    | 110           | 3/2     | 1   | 1   | 1   | 110                 | 0       | 0   | 0   | 0   |
|    | 111           | 3/2     | 3/2 | 1   | 1   | 111                 | 0       | 0   | 0   | 0   |

15 12. The apparatus of claim 11, wherein said control logic further comprises means for selecting predetermined partial quotient values for each iteration of said divide operation as a function of the true/complement value of the partial dividend at the start of said iteration, the true/complement value of the partial dividend at the end of said iteration, and the particular divisor multiple selected for said iteration, according to the following tabulation:

| 25 | STARTING PARTIAL DIVIDEND | ENDING PARTIAL DIVIDEND | DIVISOR MULTIPLIER USED |    |     |     |    |
|----|---------------------------|-------------------------|-------------------------|----|-----|-----|----|
|    |                           |                         | 3/2                     | 1  | 3/4 | 1/2 | 0  |
| 30 | T                         | T                       | 11                      | 10 | 011 | 01  | 00 |
|    |                           | C                       | 10                      | 01 | 010 | 00  | -  |
| 35 | C                         | T                       | 01                      | 10 | 101 | 11  | -  |
|    |                           | C                       | 00                      | 01 | 100 | 10  | 11 |

35 13. A method of selecting multiples of a divisor for use during respective subtractive iterations in a 2-bit, non-restoring divide sequence, wherein each iteration requires the subtraction of a divisor multiple from a dividend or partial dividend to select a partial quotient, comprising the steps of  
 a) sensing the three most significant bits of the divisor;  
 b) sensing the three most significant bits of the dividend or partial dividend;  
 c) sensing the true/complement value of the dividend or partial dividend; and  
 40 d) selecting a divisor multiplier according to the following tabulation if the dividend or partial dividend is a true value:

| 45 | TRUE DIVIDEND | DIVISOR |     |     |     |
|----|---------------|---------|-----|-----|-----|
|    |               | 100     | 101 | 110 | 111 |
| 50 | 000           | 0       | 0   | 0   | 0   |
|    | 001           | 0       | 0   | 0   | 0   |
|    | 010           | 1/2     | 1/2 | 1/2 | 1/2 |
|    | 011           | 1/2     | 1/2 | 1/2 | 1/2 |
|    | 100           | 1       | 1   | 3/4 | 3/4 |
|    | 101           | 1       | 1   | 3/4 | 3/4 |
|    | 110           | 3/2     | 1   | 1   | 1   |
|    | 111           | 3/2     | 3/2 | 1   | 1   |

55 e) selecting a divisor multiplier according to the following tabulation if the dividend or partial dividend

is a complement value:

| COMPLEMENT<br>DIVIDEND | DIVISOR |     |     |     |
|------------------------|---------|-----|-----|-----|
|                        | 100     | 101 | 110 | 111 |
| 000                    | 3/2     | 3/2 | 1   | 1   |
| 001                    | 3/2     | 1   | 1   | 1   |
| 010                    | 1       | 1   | 1   | 3/4 |
| 011                    | 1       | 1   | 3/4 | 3/4 |
| 100                    | 1/2     | 1/2 | 1/2 | 1/2 |
| 101                    | 1/2     | 1/2 | 1/2 | 1/2 |
| 110                    | 0       | 0   | 0   | 0   |
| 111                    | 0       | 0   | 0   | 0   |

5

10

15

14. A method of selecting partial quotients in respective iterations of a 2-bit, non-restoring divide sequence, wherein each iteration requires the selection of multiples of the divisor according to claim 13, comprising the steps of:

- sensing the true/complement value of the partial dividend at the start of the iteration;
- sensing the true/complement value of the partial dividend at the end of the iteration;
- sensing the value of the multiplier of the divisor used during the iteration; and
- selecting the partial quotient according to the following tabulation:

25

30

35

| STARTING<br>PARTIAL<br>DIVIDEND | ENDING<br>PARTIAL<br>DIVIDEND | DIVISOR MULTIPLIER USED |    |     |     |    |
|---------------------------------|-------------------------------|-------------------------|----|-----|-----|----|
|                                 |                               | 3/2                     | 1  | 3/4 | 1/2 | 0  |
| T                               | T                             | 11                      | 10 | 011 | 01  | 00 |
|                                 | C                             | 10                      | 01 | 010 | 00  | -- |
| C                               | T                             | 01                      | 10 | 101 | 11  | -- |
|                                 | C                             | 00                      | 01 | 100 | 10  | 11 |

15. A method for calculating a quotient of a dividend and divisor in a plurality of 2-bit, non-restoring subtraction iterations wherein a partial quotient is formed for each iteration involving a multiple of the divisor being subtracted from the dividend to form a new partial dividend of the next iteration, comprising the steps of

- sensing the three most significant bits of the divisor and dividend and selecting a divisor multiple according to the method of claim 13;
- subtracting the selected divisor multiple from the dividend to produce a new partial dividend to replace the dividend;
- selecting the partial quotient according to the method of claim 14; and
- repeats steps a) through c) for a predetermined number of iterations.

16. In an arithmetic circuit for performing floating point division according to the technique of performing iterations of 2-bit, non-restoring subtractions wherein a multiple of the divisor is subtracted from a dividend or partial dividend to form a partial quotient for each iteration, the improvement in arithmetic circuit construction comprising:

- an adder circuit for performing each of said subtractive iterations, having three inputs for receiving operands wherein the sum of a first and second input operand is subtracted from a third input operand;
- a dividend register connected to said adder circuit third input;
- a divisor register connected to said adder circuit first and second inputs;
- a multiple selector circuit connected between said divisor register and said adder circuit first and second inputs, said multiple selector circuit having means for controllably gating the contents of said divisor register into each of said first and second inputs in relative bit position alignment or in relative

blocked or shifted bit positions, whereby the gated contents of said divisor register may be respectively the 1X multiple, the 1/2X multiple, the 1/4X multiple or the 0X multiple of said divisor; and

5       e) control logic circuit means for selectively activating said multiple selector circuit means for controllably gating.

17. The apparatus of claim 16, wherein said multiple selector circuit further comprises a plurality of latches connected to said adder circuit two inputs and to outputs of said divisor register, said latches being controllable by said activation signals to gate said divisor register outputs to said adder circuit inputs in predetermined bit position transfers.

18. The apparatus of claim 17, wherein said latches further comprise means for making said predetermined bit position transfers to formulate the zero, 1/2, 3/4, 1 and 3/2 multiples of said divisor.

19. The apparatus of claim 18, wherein said means for making said predetermined bit position transfers for formulating the 3/2 multiple of said divisor further comprises means for simultaneously gating said divisor to one input of said adder circuit, and gating said divisor shifted by one bit position rightward to a second input of said adder circuit.

20. The apparatus of claim 19, wherein said means for making said predetermined bit position transfers for formulating the 3/4 multiple of said divisor further comprises means for simultaneously gating said divisor shifted by one bit position rightward to one input of said adder circuit, and gating said divisor shifted by two bit positions rightward to a second input of said adder circuit.

21. The apparatus of claim 20, wherein said means for making said predetermined bit position transfers for formulating the one multiple of said divisor further comprises means for gating said divisor directly into one input of said adder circuit, and inhibiting the gating into a second input of said adder circuit.

22. The apparatus of claim 21, wherein said means for making said predetermined bit position transfers for formulating the 1/2 multiple of said divisor further comprises means for gating said divisor shifted one bit position rightward to one input of said adder circuit, and inhibiting the gating into a second input of said adder circuit.

30

35

40

45

50

55

Fig. 1

STORAGE DATA BUS

12

14 FLOWING-POINT REGISTERS

15

16 FA REGISTER

16a

16b

17

18 FB REGISTER

18a

18b

19

20 EA

21

22 FC REGISTER

24

26

28

29

30

34 a

34 b

36

3-BIT DECODE

CONTROL SIGNALS

10

2

3

4

5

6

7

8

9

11

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214

215

216

217

218

219

220

221

222

223

224

225

226

227

228

229

230

231

232

233

234

235

236

237

238

239

240

241

242

243

244

245

246

247

248

249

250

251

252

253

254

255

256

257

258

259

260

261

262

263

264

265

266

267

268

269

270

271

272

273

274

275

276

277

278

279

280

281

282

283

284

285

286

287

288

289

290

291

292

293

294

295

296

297

298

299

300

301

302

303

304

305

306

307

308

309

310

311

312

313

314

315

316

317

318

319

320

321

322

323

324

325

326

327

328

329

330

331

332

333

334

335

336

337

338

339

340

341

342

343

344

345

346

347

348

349

350

351

352

353

354

355

356

357

358

359

360

361

362

363

364

365

366

367

368

369

370

371

372

373

374

375

376

377

378

379

380

381

382

383

384

385

386

387

388

389

390

391

392

393

394

395

396

397

398

399

400

401

402

403

404

405

406

407

408

409

410

411

412

413

414

415

416

417

418

419

420

421

422

423

424

425

426

427

428

429

430

431

432

433

434

435

436

437

438

439

440

441

442

443

444

445

446

447

448

449

450

451

452

453

454

455

456

457

458

459

460

461

462

463

464

465

466

467

468

469

470

471

472

473

474

475

476

477

478

479

480

481

482

483

484

485

486

487

488

489

490

491

492

493

494

495

496

497

498

499

500

501

502

503

504

505

506

507

508

509

510

511

512

513

514

515

516

517

518

519

520

521

522

523

524

525

526

527

528

529

530

531

532

533

534

535

536

537

538

539

540

541

542

543

544

545

546

547

548

549

550

551

552

553

554

555

556

557

558

559

560

561

562

563

564

565

566

567

568

569

570

571

572

573

574

575

576

577

578

579

580

581

582

583

584

585

586

587

588

589

590

591

592

593

594

595

596

597

598

599

600

601

602

603

604

605

606

607

608

609

610

611

612

613

614

615

616

617

618

619

620

621

622

623

624

625

626

627

628

629

630

631

632

633

634

635

636

637

638

639

640

641

642

643

644

645

646

647

648

649

650

651

652

653

654

655

656

657

658

659

660

661

662

663

664

665

666

667

668

669

670

671

672

673

674

675

676

677

678

679

680

681

682

683

684

685

686

687

688

689

690

691

692

693

694

695

696

697

698

699

700

701

702

703

704

705

706

707

708

709

710

711

712

713

714

715

716

717

718

719

720

721

722

723

724

725

726

727

728

729

730

731

732

733

734

735

736

737

738

739

740

741

742

743

744

745

746

747

748

749

750

751

752

753

754

755

756

757

758

759

760

761

762

763

764

765

766

767

768

769

770

771

772

773

774

775

776

777

778

779

780

781

782

783

784

785

786

787

788

789

790

791

792

793

794

795

796

797

798

799

800

801

802

803

804

805

806

807

808

809

8010

8011

8012

8013

8014

8015

8016

8017

8018

8019

8020

8021

8022

8023

8024

8025

8026

8027

8028

8029

8030

8031

8032

8033

8034

8035

8036

8037

8038

8039

8040

8041

8042

8043

8044

8045

8046

8047

8048

8049

8050

8051

8052

8053

8054

8055

8056

8057

8058

8059

8060

8061

8062

8063

8064

8065

8066

8067

8068

8069

8070

8071

8072

8073

8074

8075

8076

8077

8078

8079

8080

8081

8082

8083

8084

8085

8086

8087

8088

8089

8090

8091

8092

8093

8094

8095

8096

8097

8098

8099

80100

80101

80102

80103

80104

80105

80106

80107

80108

80109

80110

80111

80112

80113

80114

80115

80116

80117

80118

80119

80120

80121

80122

80123

80124

80125

80126

80127

80128

80129

80130

80131

80132

80133

80134

80135

80136

80137

80138

80139

80140

80141

80142

80143

80144

80145

80146

80147

80148

80149

80150

80151

80152

80153

80154

80155

80156

80157

80158

80159

80160

80161

80162

80163

80164

80165

80166

80167

80168

80169

80170

80171

80172

80173

80174

80175

80176

80177

80178

80179

80180

80181

80182

80183

80184

80185

80186

80187

80188

80189

80190

80191

80192

80193

80194

80195

80196

80197

80198

80199

80200

80201

80202

80203

80204

80205

80206

80207

80208

80209

80210

80211

80212

80213

80214

80215

80216

80217

80218

80219

80220

80221

80222

80223

80224

80225

80226

80227

80228

80229

80230

80231

80232

80233

80234

80235

80236

80237

80238

80239

80240

80241

80242

80243

80244

80245

80246

80247

80248

80249

80250

80251

80252

80253

80254

80255

80256

80257

80258

80259

80260

80261

80262

80263

80264

80265

80266

80267

80268

80269

80270

80271

80272

80273

80274

80275

80276

80277

80278

80279

80280

80281

80282

80283

80284

80285

80286

80287

80288

80289

80290

80291

80292

80293

80294

80295

80296

80297

80298

80299

80300

80301

80302

80303

80304

80305

80306

80307

80308

80309

80310

80311

80312

80313

80314

80315

80316

80317

80318

80319

80320

80321

80322

80323

80324

80325

80326

80327

80328

80329

80330

80331

80332

80333

80334

80335

80336

80337

80338

80339

80340

80341

80342

80343

80344

80345

80346

80347

80348

80349

80350

80351

80352

80353

80354

80355

80356

80357

80358

80359

80360

80361

80362

80363

80364

80365

80366

80367

80368

80369

80370

80371

80372

80373

80374

80375

80376

80377

80378

80379

80380

80381

80382

80383

80384

80385

80386

80387

80388

80389

80390

80391

80392

80393

80394

80395

80396

80397

80398

80399

80400

80401

80402

80403

80404

80405

80406

80407

80408

80409

80410

80411

80412

80413

80414

80415

80416

80417

80418

80419

80420

80421

80422

80423

80424

80425

80426

80427

80428

80429

80430

80431

80432

80433

80434

80435

80436

80437

80438

80439

80440

80441

80442

80443

80444

80445

80446

80447

80448

80449

80450

80451

80452

80453

80454

80455

80456

80457

80458

80459

80460

80461

80462

80463

80464

80465

80466

80467

80468

80469

80470

80471

80472

80473

80474

80475

80476

80477

80478

80479

80480

80481

80482

80483

80484

80485

80486

80487

80488

80489

80490

80491

80492

80493

80494</p

Fig. 2

Fig. 3





Europäisches Patentamt  
European Patent Office  
Office européen des brevets



⑪ Publication number:

0 394 162 A3

⑫

## EUROPEAN PATENT APPLICATION

⑬ Application number: 90480033.1

⑮ Int. Cl. 5: G06F 7/52

⑭ Date of filing: 07.03.90

⑯ Priority: 17.04.89 US 339261

⑰ Date of publication of application:  
24.10.90 Bulletin 90/43

⑱ Designated Contracting States:  
DE FR GB

⑲ Date of deferred publication of the search report:  
01.07.92 Bulletin 92/27

⑳ Applicant: International Business Machines  
Corporation  
Old Orchard Road  
Armonk, N.Y. 10504(US)

㉑ Inventor: Allen, Richard George  
2315 Telemark Lane N.W.  
Rochester, Minnesota 55901(US)  
Inventor: Freerksen, Donald Lee  
1220 41/2 Street N.W.  
Rochester, Minnesota 55901(US)

㉒ Representative: Vekemans, André  
Compagnie IBM France Département de  
Propriété Intellectuelle  
F-06610 La Gaude(FR)

### ㉓ Two-bit floating point divide circuit with single carry-save adder.

㉔ Apparatus and method for performing floating point divide operations in 2-bit, non-restoring iterations, wherein multiples of the divisor are formed by selective gating of one or more representations of the divisor into a single 3-input adder circuit, to calculate the partial quotients and subsequent partial dividends. The apparatus produces, without the need of separate holding registers, the zero, 1/2, 3/4, 1 and 3/2 multiples of the divisor.



Fig. 2

EP 0 394 162 A3



European Patent  
Office

EUROPEAN SEARCH REPORT

Application Number

EP 90 48 0033

| DOCUMENTS CONSIDERED TO BE RELEVANT                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                    | CLASSIFICATION OF THE APPLICATION (Int. Cl.5) |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Category                                                                                                                                                                                                                   | Citation of document with indication, where appropriate, of relevant passages                                                                                                                                                                                                  | Relevant to claim                                                                                                                                                                                                                                                                  |                                               |
| X                                                                                                                                                                                                                          | IBM TECHNICAL DISCLOSURE BULLETIN,<br>vol. 30, no. 6, November 1987, NEW YORK US<br>pages 415 - 419; 'RADIX 16 DIVIDER'<br>* the whole document *<br>* -/- *                                                                                                                   | 1-10,<br>16-22                                                                                                                                                                                                                                                                     | G06F7/52                                      |
| A                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                | 11-15                                                                                                                                                                                                                                                                              |                                               |
| A                                                                                                                                                                                                                          | IBM TECHNICAL DISCLOSURE BULLETIN,<br>vol. 15, no. 7, December 1972, NEW YORK US<br>pages 2263 - 2268;<br>JACKSON ET AL: 'BINARY MULTIPLICATION AND<br>DIVISION UTILIZING A THREE-INPUT ADDER'<br>* page 2263, line 1 - line 3 *<br>* page 2268, line 5 - line 10; table III * | 1-10,<br>16-22                                                                                                                                                                                                                                                                     |                                               |
| A                                                                                                                                                                                                                          | PATENT ABSTRACTS OF JAPAN<br>vol. 10, no. 3 (P-418)22 August 1985<br>& JP-A-60 160 438 ( FUJITSU )<br>* abstract *                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                  |                                               |
|                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                    | TECHNICAL FIELDS<br>SEARCHED (Int. Cl.5)      |
|                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                    | G06F                                          |
| <p>The present search report has been drawn up for all claims</p>                                                                                                                                                          |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                    |                                               |
| Place of search                                                                                                                                                                                                            | Date of completion of the search                                                                                                                                                                                                                                               | Examiner                                                                                                                                                                                                                                                                           |                                               |
| THE HAGUE                                                                                                                                                                                                                  | 23 APRIL 1992                                                                                                                                                                                                                                                                  | COHEN B.                                                                                                                                                                                                                                                                           |                                               |
| CATEGORY OF CITED DOCUMENTS                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                | T : theory or principle underlying the invention<br>E : earlier patent document, but published on, or<br>after the filing date<br>D : document cited in the application<br>L : document cited for other reasons<br>& : member of the same patent family, corresponding<br>document |                                               |
| X : particularly relevant if taken alone<br>Y : particularly relevant if combined with another<br>document of the same category<br>A : technological background<br>O : non-written disclosure<br>P : intermediate document |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                    |                                               |